package cn.iocoder.yudao.module.ao.dal.dataobject.student;

import lombok.*;

import java.time.LocalDate;
import java.util.*;
import java.math.BigDecimal;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;

/**
 * 学生信息 DO
 *
 * @author 禾安
 */
@TableName("jx_student")
@KeySequence("jx_student_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class StudentDO extends BaseDO {

    /**
     * 学生ID
     */
    @TableId
    private Long studentId;
    /**
     * 学号
     */
    private String studentNo;
    /**
     * 姓名
     */
    private String name;
    /**
     * 性别（1男 2女）
     */
    private Integer gender;
    /**
     * 身份证号
     */
    private String idCard;
    /**
     * 手机号
     */
    private String phone;
    /**
     * 邮箱
     */
    private String email;
    /**
     * 所属班级ID
     */
    private Long classId;
    /**
     * 所属专业ID
     */
    private Long majorId;
    /**
     * 入学日期
     */
    private LocalDate enrollmentDate;
    /**
     * 入学学期ID
     */
    private Long enrollmentTermId;
    /**
     * 毕业日期
     */
    private LocalDate graduationDate;
    /**
     * 当前学期数
     */
    private Integer currentSemester;
    /**
     * 已获得学分
     */
    private BigDecimal totalCredits;
    /**
     * 平均绩点
     */
    private BigDecimal gpa;
    /**
     * 监护人姓名
     */
    private String guardianName;
    /**
     * 监护人电话
     */
    private String guardianPhone;
    /**
     * 家庭地址
     */
    private String address;
    /**
     * 状态（0在读 1毕业 2退学 3休学 4转学）
     */
    private Integer status;


}